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TITLE OF INVENTION: AUTOMA.TED GENERATION OF CARD-BASED 

PRESENTATION DOCUMENTS FROM MULTIMEDIA 
DATA 



TO WHOM IT MAY CONCERN, THE FOLLOWING IS 
A SPECIFICATION OF THE AFORESAID INVENTION 



Automatic Generation of Card-Based Presentation 



Docioments from Multimedia Data 



Background of the Invention 

Field of the Invention 

The present invention relates to multimedia document 
presentations and more particularly to a system for 
automatically generating platform-independent formatting 
object descriptions from SGML documents and non-textual 
media sources which can then be used to create card-based 
multimedia presentation documents. 

Description of the Prior Art 

Traditionally, hypermedia presentations are 
interactively designed and manually created with 
hypermedia authoring tools. Various commercial 
hypermedia authoring tools adopt different interactive 
authoring paradigms but they are limited in supporting 
the automated generation of card-based presentation from 
existing multimedia document sources in large scale. The 
representative presentation authoring tools are 
summarized as follows. 

PowerPoint from Microsoft is based on a structure- 
oriented model and supports hierarchical information 
content authoring in a 2D layout. Many commercial word 
processing tools follow this authoring model. Documents 
are often developed in terms of hierarchical structures 
such as book;, pages or slides, sections, subsections, 
etc., and WYSWIG user interfaces are provided to support 
structure editing and issue formatting commands 
interactively. 
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Authorware from Macromedia and IconAuthor from 
AimTech are based on a flowchart model and use icons 
representing events such as audio or video, if-then 
functionsyr branching and hyperlinks in a linear 
5 progression like flowchart control. Content editors to 
assign real media files and properties to each icon could 
be used. This model provides high-level program control 
and global ordering of information presentation. 

Director from Macromedia, based on a time-line 

10 model, displays media sequences as tracks and specializes 
in synchronizing events. It can be used to create high- 
level multimedia presentations. 

Multimedia Toolbook from Asymetrix, based on an 
object-oriented model with scripting capability, provides 

15 more support of complex interaction behavior. Users can 
interactively enter document content (in multimedia 
objects) and define object properties including various 
formatting commands and scripts for object behavior. 
This authoring tool allows the user to get to a lower- 

20 level control of object and system behavior with script 
commands . 

Summary of the Invention 

The present invention provides a new approach for 
25 automatic generation of card-based document presentation 
from multimedia data sources. An automatic card-based 
presentation generation system programmatically creates 
card-based presentation documents from source documents. 
In the prior art, the card-based document presentation is 
30 interactively created by authoring tools. However, if 
documents are in large scale and information content 
already exists in other forms (e.g., archive formats), 
the interactively authoring process for manually creating 
presentation forms from these existing documents becomes 
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tedious and time-consuming* This invention includes an 
automated system for transforming a card layout style 
specification into presentation specifications which at 
run-time, are used to generate formatting object 
descriptions. The formatting object descriptions can 
then be used to actually create card-based presentation 
documents . 

The present invention comprises a presentation style 
transformer and a card-based presentation generator for 
generating card-based Formatting Object Descriptions 
(FOD) from the Card Layout Style Specification (CLSS) . 
The presentation style transformer takes the card layout 
style specification (CLSS) and the Card Display Schema 
(CDS) as input and transforms them into a Card-based 
Presentation Specification (CPS) . CLSS is used to 
declaratively specify the layout of the card-based 
presentation, CDS is used to specify meta rules for 
presentation resources and for variable definitions. CPS 
is a procedural specification of overall card-based 
presentation characteristics including layout, resources 
and presentation procedures. The card-based presentation 
generator takes the card-based presentation spec- 
ifications and card-based document content as input to 
create formatting object descriptions. The generator 
first uses a Presentation Construct Mapper for 
translating CPS constructs into constructs required by 
Card-Based DSSSL Style Specifications and then uses a 
Card-based DSSSL Processor to create a Card-Based 
Document Flow Object Tree. After that, the generator 
uses an FOD Converter to convert the flow object tree 
into formatting object descriptions. 

Brief Description of the Drawings 



Figure 1 illustrates a block diagram of the 



automatic card-based presentation generation system of 
the present invention. 

Figure 2 illustrates the syntax of a card layout 
style specification . 

Figure 3 gives an example of a card layout style 
specification for CardTitle. 

Figure 4 illustrates the syntax of a generated card- 
based presentation specification. 

Figure 5 gives an example of a card-based 
presentation specification for CardTitle, 

Figure 5 illustrates a block diagram of a 
presentation style transformer for translating card 
layout style specifications into card-based presentation 
specifications based on display schema specifications. 

Figure 7. illustrates a display schema for 
generating a TextbyGf xTitle resource declaration. 

Figure 8 illustrates a syntax of display schema for 
generating resource declarations or variable definitions. 

Figure 9 illustrates a display schema for generating 
content variable definitions. 

Figure 10 illustrates a display schema for 
generating all primitive resource declarations- 

Figure 11 illustrates a card-based context tree. 
Figure 12 illustrates card-based context paths. 
Figure 13 illustrates a flow chart of the content 
mapping rule generation process. 

Figure 14 illustrates examples of generated CPS for 
C/ CT and T nodes. 

Figure 15 illustrates examples of generated CPS for 
R and A nodes . 

Figure 16 illustrates a block diagram of a card- 
based presentation generator for translating card-based 
pj^esentation specifications into structured formatting 
obj ect descriptions . 



Figure 17 illustrates a generated card-based DSSSL 
style for CardTitle, 

Figure 18 illustrates some card-based DSSSL style 
functions used for CardTitle. 
5 Figure 19 illustrates a CardTitle formatting object 

description. 

Figure 20 illustrates a general syntax of formatting 
obj ect description, 

10 Detailed Description of the Invention 

This patent application is related to copending U.S. 
patent application entitled "A Generalized System for 
Automatically Hyperlinking Product Documents"^ Attorney 
Docket No. 99P7818US, filed on September 22, 1999 and 

15 assigned to the same assignee as the present invention. 

The present invention is an automatic card-based 
presentation generation system that programmatically 
generates card-based formatting object descriptions from 
large SGML textual documents and non-textual media 

20 sources. The formatting object descriptions can be used 
to automatically create card-based presentation document 
formats. The prior art of the presentation approach is 
based on interactive authoring tools for manually 
creating multimedia presentation. The interactive 

25 approach does not support creating large-scale 

presentation documents for industrial applications due to 
required human involvement in the authoring process. 

The overall card-based presentation generation 
system is described in Figure 1. The generation system 

30 comprises presentation style transformer 12 and card- 
based presentation generator 14. Presentation style 
transformer 12 receives a card layout style specification 
(CLSS) , examples of which are shown in Figures 2 and 3. 
The CLSS language is described in US Patent Application 



5 



serial number 08/984,734 filed on December 4, 1997, 
entitled "'Style Specifications For Systematically 
Creating Card-Based Hypermedia Manuals'' and assigned to 
the same assignee as the present invention* Presentation 
style transformer 12 also receives a card display schema, 
an example of which is shown in Figure 8. Presentation 
style transformer 12 generates a card-based presentation 
specification, shown in Figures 4 and 5, as output. The 
generated card-based presentation specification comprises 
two parts: MACRO resource declarations and procedural 
element mapping rules. 

Card-based presentation generator 14 receives both, 
the card-based presentation specification and the SGML 
document content as inputs and generates platform- 
independent formatting object descriptions, FODs, as 
output. Formatting object descriptions are abstract 
descriptions of formatting directives of presentation 
documents. Once FODs are created, an automatic scripting 
process can be used to generate a card-based document 
presentation. The automatic scripting process is 
described in US Patent Application serial number 
08/986,270 filed on December 5, 1997, entitled 

Formatting Card-Based Hypermedia Documents By Automatic 
Scripting'' and assigned to the same assignee as the 
present invention . 

Presentation style transformer, 12 of Figure 1, is 
shown in greater detail in Figure 6, The presentation 
style transformer comprises two major components: 
resource generator 22 and style proceduralizer 24. 
Resource generator 22 is based on the card display schema 
and creates presentation resource declarations from the 
card-based layout style specification. Card presentation 
resource declarations include two types of resources: 
MACRO_Resouxce(styiename^ parameters) for primitives and 
MACRO name { sty lenamer parameters) for composites. The 



first argument of a MACRO resource declaration must be a 
stylename. Primitive resources are used for basic 
presentation object resource requirements of the target 
presentation platform. Composite resources can be 
defined in terms of primitive ones or other composite 
resources . 

Resource generator 22 creates MACRO resource 
declarations by examining the objects inside background 
list and background list of card-based style 
specifications and the corresponding card display schema 
for the objects. As an example, the generated CardTitle 
MACRO resource declaration is shown in Figure 5. This 
generation procedure is triggered by the TextByGf xTitle 
style layout specification shown in Figure 3. The 
corresponding display schema, shown in Figure 7, is used 
to guide the generator to create the TextByGf xTitle 
resource declaration with default values of their 
parameters. The MACRO_TitleField specifies the needed 
presentation objects and the variable $CardTitle_RTF$ 
whose value would be calculated by a predefined DSSSL 
function RTF-TitleGen from source document content at 
run- time * 

The display schema syntax is shown in Figure 8. It 
can be used to guide the generator for both creating 
resource declarations in the <MACRO_Declaration> part and 
variable definitions in the <ContentMapping> part of the 
card-based presentation specification. Display schema 
for generating a variable definition of $CardTitle_RTF$ 
is done by style proceduralizer 24, shown in Figure 9. 
Display schema for generating all primitive resource 
declarations is shown in Figure 10. 

Style proceduralizer 24, in Figure 6, comprises 
three components: context tree builder 2 6, content node 
path walker 28 and content mapping rule generator 30. 
Context tree builder 26 creates a context tree for rule 



generator 30 to create content mapping rules along 
content node paths in the tree. Style proceduralizer 24 
translates a declarative card layout style specification 
into procedural card content mapping rules. For example, 
5 CardTitle element content mapping is shown in Figure 5. 
The first element mapping rule procedurally specifies the 
following things: Any document content with tag CardTitle 
or ANYDOCX under document tag CARDX which is under tag 
CARD will use an element rule with matched context tags 

10 for creating formatting object descriptions. Since the 
second element rule matches the context tags (Card, 
CardX, CardTitle) , it will be invoked for further 
specifying how to create formatting object descriptions 
for CardTitle. The second rule basically specifies which 

15 types of formatting objects are created by using a 

stylename attribute value under a different cardtype. 

Context tree builder 26 takes all context 
information in the card layout style specifications as 
input and constructs a context tree as output by 

20 examining and ordering all context tags appearing in the 
context and AIU attribute values in the layout 
specifications, by grouping the same context 
specification into one with type differences, and by 
marking context tags into the following categories: R 

25 (root node), C (content node) for both being a leaf node 
of context tree and the last element of some context 
attribute value, T (transition node) for both being a 
non-leaf node and non-content node, CT 

(content/transition node) for both being a non-leaf node 
30 of context tree and the last element of some context 

attribute value, and A (associated node) from attribute 
AIU values for the context of associated AIU in graphics. 
The context tree is designed to capture content mapping 
rule context for making an efficient generation process 
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of procedural rule mappings in CPS. As an example, a 
context tree is shown in Figure 11. 

Content node path walker 28 takes the context tree 
as an input and finds all context paths as the output. 
5 The context paths are defined to be the shortest paths 
from the root node to each C, CT and A nodes as shown in 
Figure 12. 

Content mapping rule generator 30 uses categories 
and types of nodes to generate constructs of content 
10 mapping rules. The detailed process in shown in Figure 
13. Examples are shown in Figures 14 and 15. 

For transition nodes, mapping rule generator 30 adds 
element rule constructs which simply specify how to pass 
rule processing to their children in the context tree. 
^! 15 For content nodes ^ the mapping rule generator adds 

4- specifications of the formatting object descriptions. 

2 For content transition nodes, it adds rule specifications 

^ for both content and transition functionality. For root 

[| and associated nodes, the mapping rule generator adds 

1,^, 20 predefined and domain-specific presentation 

yi specifications. Particularly for the root node, the rule 

^ generator adds the specifications of defining an overall 

^.a card-based presentation structure. For associated nodes, 

^ the mapping rule generator adds structure-specific 

25 association specifications. For instance, the structure- 
specific specifications can be related to hotspots, 
annotations, or animation objects associated with graphic 
obj ects . 

Card-based document presentation generator (14 of 
30 Figure 1) shown in Figure 16 comprises the following 

components: presentation construct mapper 42, card-based 
DSSSL processor 44 and FOD converter 46. 

Presentation construct mapper 42 is used to map 
constructs in CPS into Card-based DSSSL constructs shown 
35 in Figures 17 and 18, The mapping procedure is a one- 
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pass translation from CPS to a card-based DSSSL style 
specification as follows. Card-based DSSSL style speci- 
fication uses the ISO standard document style language, 
called DSSSL (Document Style Semantics and Specification 
Language) . 

(1) Map CPS ElementRule context into card-based 
DSSSL element context. 

(2) Map CPS CaseExpr and IfExpr into card-based 
DSSSL case and if functions. 

(3) Map CPS MACRO_Declaration into card-based 
predefined DSSSL functions. 

(4) Map CPS ProcessGrove into card-based DSSSL 
Process function . 

(5) Map CPS DefineVar, AddObject and AddGroup into 
card-based DSSSL FODfo flow object instance. 

This mapping process is very efficient, since CPS is 
designed to be as close to card-based DSSSL style 
specification as possible. In particular, the card-based 
DSSSL style specifications are based on one universal 
card-based presentation flow object, called FODfo, for 
creating the card-based document flow object tree as 
shown in Figure 16. A card-based document flow object 
tree consists of a sequence of FODfo object instances. 
It is an abstract representation of card-based document 
formatting object descriptions. Using this single 
universal flow object can greatly simplify mapping of 
constructs from CPS to card-based DSSSL style 
specifications . 

To create an instance of FODfo flow object, the 
mapper only needs to make a DSSSL function laakeFODfo 
call, which takes three keyed arguments: FOtype, FOname 
and FOinstruction. FOinstruction is a data string that 
represents formatting information such as the 
presentation object attribute values. The key concept 
here is that FODfo flow object is designed in such a way 
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that a complete card-based formatting object description 
can be composed by appending a sequence of FODfo object 
instances. Thus, a FOD can be created by a DSSSL 
predefined function sosofo-append (specification of 
5 s^equence of flow object-append) to append all FODfo 
instances , 

Card-based DSSSL processor 44 is used to create a 
card-based document flow object tree. This is an 
abstract representation of card-based document formatting 
10 descriptions and it comprises a sequence of FODfo flow 
objects. Each FODfo flow object contains an SGML data 
string of FOD and each FODfo flow object is designed for 
uniformly representing card-based formatting object 
information . 

15 Finally^r FOD converter 4 6 is used to convert this 

abstract representation of sequences of FODfo objects 
into FODs, i.e., formatting object descriptions, shown in 
Figures 19 and 20. 

The card-based presentation specification is designed 

20 for bridging the gap between the declarative card layout 
style specification and the procedural card-based DSSSL 
style specification. These specifications can be 
automatically generated from card layout style 
specifications and can be used for automatically 

25 generating card-based DSSSL style specifications. 

It is not intended that this invention be limited to 
the hardware or software arrangement or operational 
procedures shown disclosed. This invention includes all 
of the alterations and variations thereto as encompassed 

30 within the scope of the claims as follows. 
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CLAIMS 



1, A system for automatic generation of card-based 
5 presentation documents from multimedia data comprising: 
a presentation style transformer; and 
a card-based presentation generator connected to 
said presentation style transformer. 

10 2. A system for automatic generation of card-based 

presentation documents from multimedia data as claimed in 
claim 1 wherein said presentation style transformer 
comprises : 

a processor for receiving a card display schema and 
15 for processing said card display schema to describe meta 
rules about presentation resources and content variable 
definitions for a card-based presentation specification. 

3. A system for automatic generation of card-based 
20 presentation documents from multimedia data as claimed in 

^ claim 1 wherein said presentation style transformer 

comprises : 

a resource generator; and 
a style proceduralizer . 

25 

4. A system for automatic generation of card-based 
presentation documents from multimedia data as claimed in 
claim 3 wherein said style proceduralizer comprises: 

a card-based context tree builder; 
30 a content node path walker connected to said card- 

based context tree builder; and 

a content mapping rule generator connected to said 
content node path walker, 

35 5. A system for automatic generation of card-based 

presentation documents from multimedia data as claimed in 



12 



claim 1 wherein said card based presentation generator 
comprises : 

a presentation construct mapper; 

a card-based DSSSL processor connected to said 
5 presentation construct mapper; and 

an FOD converter connected to said card-based DSSSL 
processor . 

6. A system for automatic generation of card-based 

10 presentation documents from multimedia data comprising: 

presentation style transformer means for receiving a 
card layout style specification and a card display schema 
and for providing a card-based presentation 
specification; and 

15 card-based presentation generator means connected to 

said presentation style transformer means for receiving 
said card-based presentation specification and a card- 
based document content and for providing formatting 
ob j ect descriptions . 

20 

7. A system for automatic generation of card-based 
presentation documents from multimedia data as claimed in 
claim 6 wherein said presentation style transformer means 
comprises ; 

25 resource generator means for receiving said card 

layout style specification and said card display schema 
and for providing said card-based presentation 
specification; and 

style proceduralizer means for receiving said card 

30 layout style specification and said card display schema 
and for providing said card-based presentation 
specification , 

8. A system for automatic generation of card-based 

35 presentation documents from multimedia data as claimed in 
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claim 7 wherein said style proceduralizer means 
comprises : 

card-based context tree builder means for receiving 
said card layout style specification and for providing a 
5 context tree; 

content node path walker means connected to said 
card-based context tree builder means for receiving said 
context tree and for providing context paths; and 

content mapping rule generator means connected to 
10 said content node path walker means for receiving said 
context paths and said card display schema and for 
providing said card-based presentation specification. 

9. A system for automatic generation of card-based 
15 presentation documents from multimedia data as claimed in 
claim 8 wherein said context tree captures content 
mapping rule context for making an efficient generation 
process of procedural rule mappings in CPS. 

20 10. A system for automatic generation of card-based 

presentation documents from multimedia data as claimed in 
claim 6 wherein said card based presentation generator 
means comprises: 

presentation construct mapper means for receiving 

25 said card-based presentation specification and for 
providing card-based DSSSL style specifications; 

card-based DSSSL processor means connected to said 
presentation construct mapper means for receiving said 
card-based DSSSL style specifications and said card-based 

30 document content and for providing a card-based document 
flow object tree; and 

FOD converter means connected to said card-based 
DSSSL processor means for receiving said card-based 
document flow object tree and for providing said 

35 formatting object descriptions. 
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11. A system for automatic generation of card-based 
presentation documents from multimedia data as claimed in 
claim 10 wherein said card-based document flow object 

5 tree comprises: 

a specification of a sequence of FODfo flow objects. 

12. A method for automatic generation of card-based 
presentation documents from multimedia data comprising 

10 the steps of 

transforming a presentation style; and 
generating a card based presentation. 

13. A method for automatic generation of card-based 

15 presentation documents from multimedia data as claimed in 

claim 12 wherein transforming a presentation style 

comprises the steps of: 

resource generating presentation resource 

descriptions; and 
20 translating declarative card layout style 

specifications into procedural card-based presentation 

specifications . 



14. A method for automatic generation of card-based 

25 presentation documents from multimedia data as claimed in 
claim 13 wherein translating declarative card layout 
style specifications comprises the steps of: 
building a card-based context tree; 
building context paths; and 
30 generating a content mapping rule. 

15. A method for automatic generation of card-based 
presentation documents from multimedia data as claimed in 
claim 14 wherein generating a content mapping rule 

35 comprises the steps of: 

15 



getting a next context path; 
deciding whether last path; 
visiting a next node; 
deciding whether end of path; 
5 deciding whether node is visited before; 

creating a context attribute value; 
creating <DefineVAr>s for rule mapping; 
creating <CaseExpr> or <IfExpr> if multiple node 
types exist; and 
10 deciding a node category. 



16. A method for automatic generation of card-based 
presentation documents from multimedia data as claimed in 
15 claim 12 wherein generating a card based presentation 
comprises the steps of: 

mapping CPS constructs into card-based DSSSL style 
constructs; 

creating card-based document flow object tree; and 
20 converting card-based document flow object tree into 

formatting object descriptions- 
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Abstract of the Disclosure 



5 An automatic card-based presentation generation 

system programmatically creates card-based presentation 
documents from source documents by transforming a card 
layout style specification into presentation 
specifications which at run-time, are used to generate 
10 formatting object descriptions. The formatting object 

descriptions are then used to actually create card-based 
presentation documents. The invention includes a 
presentation style transformer and a card-based 
presentation generator. The presentation style 
15 transformer takes a card layout style specification 

(CLSS) and a card display schema (CDS) and transforms 
them into card-based presentation specifications (CPS) . 
k4 The card-based presentation generator takes the card- 

^ based presentation specifications and a card-based 

IM 20 document content to create formatting object 

descriptions . 
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Card-Based Document Content 
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Presentation Style 
Transformer 



Card-Based Presentation Specification 
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Card-Based Presentation 
Generator 



Formatting Object Descriptions (FDD) 



Figure 1. Presentation Generation Process 



<CafdLay©utStyle Hame^name . . . > 

<Options size=caroLs/ze ...>... </Options> 

<BackgroundList> 
<Background name=na/7?e Func=function_name> 
<object property^ . . . ></> 

</Background> 

<Backg round name= name Fujnc=function_name> 
Kobject property= . . . ></> 

</Background> 

</BackgroundList> ... 
<ForegroundList> 
<Foreground name-name F\jnc=function_name> 
<object property^ , . . ></> 

</Foreground> 

<Foreground name=name Func=ft/ncf/on_name> 
<object property^ . - - ></> 

</Foreground> 

</ForegroundList> 

<CardSeq name=name ConXexi=contextType=type Content =confenf> 

<Background S\y\eReUbackground_name> 
</CardSeq> 

<CardSeq name=name ConXexX=contextType=type Content =confenf> 

<Background StyleRef=t»ac/cgrouncLname> 
</CardSeq> 

<Card name=name Context=confexf Type=fype Content=:Confenf> 

<Foreground SV;/\eRei^background_name></> 
</Card> 

<Card name=name Context=confexf Type :^fype Content=confenf> 

<Foreground StyleRef=£?ac/cgrounaLname></> 
</Card> 

<CardLayoutStyle> 



Figure 2. Card Layout Style Specification 



<CardLayoutStyle Name=name . . .> 

<Options s\ze=card__size ...>... </Options> 

<BackgroundList> 
<Background name=name Func=functfon_name> 
Kobject property= . . . ></> 

</Background> 

<Background name=r?a/7?e Fur\c-function_name> 
<object property= , . . ></> 

<:/Background> 

</BackgroundList> . . . 
<ForegroundList> 

<Foreground name=:"TextByGfxForeground" Func=TextByGfxForeground''> 
<Object Nanne="TextByGfxTitle" 

Coords="1 80,1 395,1 1 50,1 305" 

Type=Tield" 

Func="TitleText" 

Gontext="Card,CardX, GardTitle" 

FontSi2e="15" 

FontStyle="Bold" 

FontColor=:"blue" 

Content="CardTitle"></> 

<Object Nanne="GfxContent" 

Coords="357 94 881 693" 

Type="Graphics" 

Func="GfxContent" 

Context="Card,CardX, AnyDocX, Figure, Graphic" 
Content="Graphic" 

AIU="Card, CardX, AnyDocX, Figure, AlUDoc, ROI"></> 
</Foreground> 
</ForegroundList> 

<CardSeq name='TextByGfxSeq Type="TextByGfx" 
Context="PlantLeve!,CardSeq" Content=""> 
<Background Sty!eRef="NornnalBackground"> 
</CardSeq> 

<Card name="TextByGfxCard" Type="TextByGfx" 

Context="PlantLevel, CardSeq, Card" Content=""> 
<Foreground StyleRef="TextByGfxForeground"></> 
</Card> 

<CardLayoutSty!e> 



Figure 3. Example of CardTitle Layout Style Specifications 



<MACRO_Declaration> 

<ObjectGroup name-"project_resource"> 

MACRO JR&souvcG(stylename, type, filename)<J> 
M ACRO_Resource(5fy/ename, type, filename)<l> 

</ObjectGroup> 

MACRO _name{stylename, parameters) <l> 
MACRO_name{stylename, parameters) <l> 

</MACRO_Declaration> 
<ContentMapping> 

<ElementRule ConX^xX^docj:ags> 

<DefmeVar name=...> 

<DefineVar name=...> 

<CaseExpr key= . , . > 
<CaseClause matchvalue= , . , > 
<AddObject otype= . . . stylename= . . . > 
<ProcessGrove command= . , . ></> 

<AddGroup groupnanie= . . . ></> 

</AddObject> 
</CaseClause> 

<CaseClause matchvalue= . . . > 
<AddObject otype= . . . stylename= . . . > 
<ProcessGrove comniand= . . . ></> 

<AddGroup groupname= . . . ></> 

</AddObject> 
</CaseClause> 
</CaseExpr> 
</ElemeiitRule> 

<ElementRule ...>.,. </> 

</ContentMapping> 



Figure 4. Card-Based Presentation Specification 



<MACRO_Declaration> 

MACRO_TitleField(TextByGfxTitle, "180,1395,1150, 1305, "$CardTitle^RTF$, 15", "bold", "blue") 

</MACRO_Deciaration> 

<ContentMapping> 

<ElementRule context="(Card CardX)"> 
<ProcessGrove 

command="process-matching-childr6n CardTitle"> 
<ProcessGrove 

command="process-matching-children ANYDOCX"> 
</ElementRule> 

f <ElementRule context="(Card CardX CardTitle)"> 

fj: <DefineVar name="$CardTitle_RTF" forvalue="(RTF-TitleGen (current node))"></> 

<CaseExpr key- "(CardType (current-node) )"> 

<CaseClause matchvalue= "GfxonlyCard"> 

<AddObject otype="Field" stylename="GfxOnlyTitle"></> 
^ </CaseClause> 

^ <CaseClause matchvalue= "TextByGfxtitle"> 

fy <AddObject otype="Fieid" stylename="TextByGfxTitie"></> 

flj </CaseClause> 

y| <CaseGlause matchvalue= "e[se"> 

^ <AddObiect otype="Field" stylename='lextByGfxTitIe"></> 

</CaseGlasuse> 
</CaseExpr> 
</ElementRule> 
<ElennentRule> ...</> 

</ContentMapping> 



Figure 5. Example of Card-Based Presentation Specification for CardTitle 
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Figure 6. Presentation Style Transformer 
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<DisplaySchema Objectype=Tieid" Name^rTextByGfxTitle"' > 
<Argument name="StyleNanne" type="Requireci" 

AvailVuie="#ANY_UNiQUE_NAME"> 
<Argument name="vertices" type="Required" 

Avaiialue="#ANY_2POINTS"> 
<Argument name='TitleRTF" type="Optional" 

DefaultValue=$CARDTiTle_RTF$" > 
<Argument name=TontSize" type="Optionar 

DefaultValue="1 5" AvailValue=:"#Number> 
<Argument name="Fontstyle" type="Optionar 

DefaultVa!ue="Regular" AvailValue="Bold,Regular, ltalic"> 
<Argument name="FontColor'* type="Optional" 

DefaultValue="Black" AvailValue="#ANY_Color„Name or RGBStoke" 
</DisplaySchema> 



Figure 7. Display Schema for Generating MACRO_ TitleField 



<DisplaySchema Objectype= object_Jype Name=r macro^name or varaiable_name> 
<Argument name= . . . type= . . . 

DefaultValue= . . . AvailVatue= . . . > 
<Argument name= . . . type= . . . 

DefaultValue= . . . AvailValue= . . . > 
<Argument name= . . . type= . . . 

DefauItValue= . . . AvailVaiue= . . . > 

</DisplaySchema> 



Figure 8. Display Schema for Generating Resource Declarations or Variable Definition 



<DisplaySchema Objectype='DefineVar" Name="$CardTitle_RTF$" > 
<Argument name="RTF-Gen" type="Required" 

AvailValue="#ANY-DSSSL-FUNC-NANME"> 
<Argument name="context" type="Optional" 
DefaultValue=:"(Card Title)"> 
</DisplaySchema> 

Figure 9. Display Schema for Generating Content Variable Definitions 



<DisplaySchema Objectype='Resource" MacroName=r'MACRO_Resource"> 
<Argument nanne="Format" type="Optional" 

DefaultValue="icon" AvailVaiue="icon,bitmap,sharedscript, nnenubar"> 
<Argument name="StyleName" type="Required" 

AvailVule="#ANY_UNIQUE_NAME"> 
<Argument name="lnstanceNAme" type="Optionar' 

DefaultValue=""AvailValue="#ANY_STRING"> 
<Argument name="FileName" type="Required" 

AvailVa!ue="#ANY_STRINGr"> 
</DisplaySchema> 



Figure 10, Display Schema for Generating all Primitive MACRO. Resources 



CardManual [R Node] 
PlantLevel [T Node] 



I 

ntl 

i 

CardSeq [CT node] Type: GfxOnly, TextByGfx 

1 

Card [CT node] Type: GfxOnly, TextByGfx 

1 



CardX [T node] 




AnyDocX [CT node] CardTitle[C node] 

/ 

Figure [T node] 

/ 

AIUDoc [T node] Graphic [C node} 

/ 

ROI [A node] 

Figure 11. Example of Card-Based Context Tree 



1. CardManual, PlantLevel, CardSeq 

2. CardManual, PlantLevel, CardSeq, Card 

3. CardManual, PlantLevel, CardSeq, Card, CardX, CardTitle 

4. CardManual, PlantLevel, CardSeq, Card, CardX, AnyDocX 

5. CardManual, PlantLevel, CardSeq, Card, CardX, AnyDocX, Figure, Graphic 

6. CardManual, PlantLevel, CardSeq, Card, CardX, AnyDocX, Figure, AIUDoc, ROI 



Figure 12. Example of Card-Based Context Paths for C, CT and A Nodes 
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Figure 13. Content Mapping Rule Generation Process 



(A) Transition Node: CardX 

<ElementRule context^" (Card CardX) "> 
<ProcessGrove 

coinmand= " process-mat ching- chi Idren CARDTITLE " >< / > 
<ProcessGrove 

command= " process -mat ching - chi Idren ANYDOCX " >< / > 
< / ElementRule> 

(B) Content Node: CardTiTle (See Figure 5) 

(C) Content Transition Node: CardSeq 

<ElementRule context^" {PlantLevel CardSeq) "> 
<Def ineVar name= " $Page_currentObj ect$ " 

strValue=" (currentObjectGen (current-node) ) "> </> 
<DefineVar </> 

<CaseExpr key= " { cardSeqType (current-node) ) "> 
<CaseClause inatchval= "GfxOnly"> 

<AddObject otype=Background styleName= "Gf xOnlyBackground" > 
<ProcessGrove 

command^ "process -matching- chi Idren CARD"></> 
</AddObject> 
</CaseClause> 

<CaseClause matchval= "TextByGfx"> 

<AddObject o type = Background styleName^ "NormalBackground"> 
<AddObject o type = But ton styleName= "Top"></> 
<AddObject otype=Button styleName= " First " ></> 
<AddObject otype=Button styleName=" Previous "></> 
<AddObject otype=Button styleName="Next "></> 
<AddObject otype=Button styleName= "Last "></> 
<AddObject o type = But ton styleName= "Audio " ></> 
<AddObject otype=Button styleName= "Animate "></> 

<ProcessGrove 

command^ "process-matching-chi Idren CARD"></> 
</CaseClause> 

<CaseClause matchval= "else" > 

< /CaseClause> 

</CaseExpr> 
</ElementRule> 



Figure 14. Example of Generated CPS for C, CT and T Nodes 



(D) ROOT NODE: CardManual 

<ElementRule context= "CardManual " > 
<AddObject otype=CardManualLayout styleName=" " > 
<DefineVar name=" $BookTOC$" strValue=" (TOC-Gen ( current -node ) ) 
<AddObject otype=ToolBookManual styleName= " IMIS_ToolBook" > 
<AddGroup groupName= " Pro ject _Resources"> </> 

<AddObject o type =MainVi ewer styleName="MainViewer " > 
<ProcessGrove 

coinmand="process-matching-children PLANTLEVEL " >< / > 
<AddGroup groupName="IMIS„MiscViewersContent"> </> 
</AddObject> 

<AddGroup groupName= " IMIS„Misc Viewers " > </> 
</AddObject> 
</AddObject> 
</ElementRule> 

(E) Associated Node: ROI 

<ElementRule context=" (Card CardX AnyDocX Figure AIUDoc ROI) "> 
<Def ineVar name= " $AiuName$ " 

strValue=" (getattr NAME ( current -node) ) "> </> 

<CaseExpr key=" (cardType ( cur rent -node) ) "> 

<CaseClause matchval= "Gf xOnly " > . . , </CaseClause> 
<CaseClause matchval= " TextByGf x " > 
<CaseExpr key=" (ROI -TYPE (current-node) ) "> 
<CaseClause niatchval=" polygon" > 

<AddObject otype=Polygon styleName="GfxContent-AIU-Poly"></> 
</> 

<CaseClause inatchval="callout"> . ,</> 
<CaseClause matchval="NamedCallout "> . .</> 

</CaseExpr> 
< /CaseClause> 

<CaseClause matchval="else"> 

<EmptySosof o> 
</CaseClause> 

</CaseExpr> 

< /ElementRule> 



Figure 15. Example of Generated CPS for R and A Nodes 
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Figure 16. Hypermedia Document Presentation Generator 



(element (Card CardX CardTitle) 
(sosofo-append 

(makcFODfo FOtype: "DefmeVar" 

FOname: "$CardTitIe_RTF$" 
FOinstruction: (RTF-TitleGen (current Node))) 
(case (cardType (current-node)) 
(("GfxOnly") 

(makeFODfo FOtype: "StartTag" 
FOname: "Field" 

FOinstruction: (AttributeGen GfxOnlyTitle))) 

(("TextByGfx") 

(makeFODfo FOtype: "StartTag" 
FOname: -"Field" 

FOinstruction: (AttributeGen TextByGfxTitle))) 

(else 

(makeFODfo FOtype: "StartTag" 
FOname: "Field" - 

FOinstruction: (AttributeGen TextByGfxTitle))) 

) 

) 

) 



Figure 17. Generated Card-Based DSSSL Style for CardTitle 



(define (AttributeGen type) 
(case type 
( ( "TextByGfxTitle" ) 
(string -append 

FontSize="\15\" " 
" FontStyle="\bold\" " 
" FontColor="\0»0,255\" " 
" RGBFILL=\"255,255,255\" " 
" TRANSPARENT=\"true\" " 
» VERTICES^\"180, 1395, 1150, 1305\" " 
" RICHTEXT=\"$CardTitle_RTF$\" " 
" FONTFACE=\" Times New Roman\" " 
" ACTIVATED=\" true\" " 
" BASELINES^VfalseX" " 
" BORDERSTYLE=\"none\" " 
" FIELDTyPE=\ " wordwrap \ " " 
» SCROLL==\"0\" " 

" SPACING=\"1\" " 

" INDENTS=\"0, 0, 0\" " 

" TABSPACING=\"360\" " 

" TABTYPE=\"left\" " 

" TEXTALIGNMENT=\"lef t\" " 

" NAME=\"TitleField\" ") ) 
( ( "GfxOnlyTiTle" ) 

. . .) 



{define (makeFODfo #! key FOtype FOname FOinstruction) 
(case FOtype 
( ("StartTag") 
(make FOD-Instruction 

data: (string-append FOname FOinstruction "> "</>" ))) 

{ ("Def ineVar") 
(make FDD- Instruct ion 

data: (string-append "<DefineVar name=" FOname "value=" FOinstructi 

{ ( " EndTag " ) 
(make FDD- instruct ion 

data: ( string -append "</>"))) 

(else 

(make FDD- instruct ion 

data: (string -append "newFlowObjecttype" ) ) ) 

) 



Figure 18. Card-Based DSSSL Style Functions for CardTitle 
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<CarciFormattingBook property- . . . > 

<Resource property= ...>... </Resource> 
<Resource property= ...>... </Resource> 

<MainViewer property- . , . > 
<StartBkgnd property^ . . . > 
<Object property^ . . . > 

<StartPage property^ ...>,., </StartPage> 
<NextPage property^ . , . > 
<Field Names "TitleField" 

TextAligment="left" 

TabTVpe="left" 

TabSpacing="360" 

Scroll=:"0" 

FielciType=:"worciwrap" 
BorderStyle="none" 
BaseLines"false" 
Activated=:"true"> 
Fontfaces'Time New Roman" 
Vertice=:"1 80,1 395,1 1 50,1 305" 
Transparent=:"True" 
RichTextr: 

■ {\rtf INanai \d«f f 5\d«f tal)360\d«£laiigl033 
(Xeonttbl 

{ \ f 1 \ f romanX f char8ttt2 \ f prq2 Syinbol i } 
{\f2\£tech Marl«tt;> 

{\f4\£roman\£chars«t0\fpra2 Tiaws N«w Roman;} 

{\f5\£8wiss\fchars«tO\£prq2 ArlaX;} 

{\£10\£swlsa\£char8«tO\£prq2 Syatttm;}} 

{\colortbl; \r*dO\firr«exiO\bla«0; \rad0\ara«n0\blu«255; 

\r«d2S5\firr»«iO\blu«0; \r*d255\gr««i255\blu«255 ; } 

\pard\plain \£4\£820 {\b\i\£5\£s36\c£l C02 Purff« System 1) 

>■ 

RGBFill="255,255,255" 
fontsize=: "15" 
fontStylez: "bold" 
rgbStroke= "0, 0, 255" 

> 

</NextPage> 

<NextPage property= ...>... </NextPage> 
</StartBkgnd> 

<NextBkgnd property^ ...>... </NextBkgnd> 
</MainViewer> 

<V!ewer property- ,..>... <A/iewer> 
</CardFormattingBook> 



Figure 19. CardTile Formatting Object Description 
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<CardFormattingBook property=^ . . . > 

<Resource property- ...>... </Resource> 
<Resource property^ ...>... </Resource> 

<MainViewer property^ . . . > 
<StartBkgnd property^ . . , > 
<Object property^: . , , > 

<StartPage property^ . . . > 
<Obiect property= . . . > 

</StartPage> 

<NextPage property^ . . . > 
<Object property^ . . . > 

</TsiextPage> 

<NextPage property- . . . > 
<Object property= . . . > 

</NextPage> 

</StartBkgnd> 

<NextBkgnd property- ...>... </NextBkgnd> 
</MainViewei> 

<Viewer property^: ,.,>... <A/iewer> 
<Viewer property^ ...>... <A/iewer> 

</CardFormattingBook> 



Figure 20. Card-Based Formatting Object Description 



